Microsoft Technologies Binding Data Context এবং Data Template গাইড ও নোট

234

XAML (Extensible Application Markup Language) একটি ডিক্লারেটিভ ভাষা যা ডাটা বাইন্ডিং, ডাটা কন্টেক্সট, এবং ডাটা টেমপ্লেট ব্যবহারের মাধ্যমে ইউজার ইন্টারফেস (UI) তৈরির জন্য ব্যবহৃত হয়। Binding, Data Context, এবং Data Template এই তিনটি কনসেপ্ট XAML এ ডাটা ভিউ (View) এবং মডেল (Model) এর মধ্যে একটি শক্তিশালী সংযোগ তৈরি করে।


Binding (ডাটা বাইন্ডিং)

Data Binding হল একটি প্রক্রিয়া যার মাধ্যমে UI উপাদান এবং ডেটা মডেলের মধ্যে একটি ডায়নামিক সংযোগ তৈরি করা হয়। এর মাধ্যমে UI উপাদানগুলোর মান পরিবর্তন করতে ডেটা মডেল থেকে সরাসরি ভ্যালু নেওয়া এবং UI থেকে ডেটা মডেলে পরিবর্তন পাঠানো সম্ভব হয়।

ডাটা বাইন্ডিং এর উদ্দেশ্য:

  • UI এবং ডেটা মডেলের মধ্যে সিঙ্ক্রোনাইজেশন।
  • কোডের পরিমাণ কমানো এবং রিডেবিলিটি বাড়ানো।
  • UI উপাদানগুলির ডেটা নির্ভরযোগ্যভাবে প্রদর্শন।

উদাহরণ:

<TextBlock Text="{Binding Name}" FontSize="20"/>

এখানে:

  • Text="{Binding Name}" ডাটা বাইন্ডিং এর মাধ্যমে Name প্রপার্টি (যেটি ViewModel বা মডেল থেকে আসছে) TextBlock এর Text প্রপার্টিতে বাইন্ড করা হচ্ছে।

বাইন্ডিং টাইপস:

  • One-way Binding: ডেটা শুধুমাত্র এক দিকে চলে (ডেটা মডেল থেকে UI)।
    উদাহরণ: {Binding Name}
  • Two-way Binding: ডেটা দুই দিকে চলে (UI থেকে মডেল এবং মডেল থেকে UI)।
    উদাহরণ: {Binding Name, Mode=TwoWay}
  • One-time Binding: ডেটা একবারই বাইন্ড হয় (UI লোড হওয়ার সময়)।
    উদাহরণ: {Binding Name, Mode=OneTime}
  • One-way to Source Binding: UI থেকে মডেলে ডেটা বাইন্ড করা হয়।
    উদাহরণ: {Binding Name, Mode=OneWayToSource}

Data Context (ডাটা কন্টেক্সট)

Data Context হল একটি প্রপার্টি যা XAML ফাইলে নির্দিষ্ট করে দেয় কোন ডেটা মডেল বা ভিউ মডেলকে UI উপাদানটি বাইন্ড করবে। এটি উপাদান বা তার প্যারেন্ট উপাদানের জন্য একটি ডেটা কন্টেক্সট সরবরাহ করে, যা UI উপাদানগুলির ডাটা বাইন্ডিং সেটিংসের জন্য দরকারি।

উদাহরণ:

<Window x:Class="MyApp.MainWindow" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" Title="Main Window" Height="350" Width="525">
    <Window.DataContext>
        <local:UserViewModel/>
    </Window.DataContext>
    <Grid>
        <TextBlock Text="{Binding UserName}" FontSize="24" HorizontalAlignment="Center" VerticalAlignment="Center"/>
    </Grid>
</Window>

এখানে:

  • Window.DataContext ব্যবহার করে UserViewModel কে ডাটা কন্টেক্সট হিসেবে সেট করা হয়েছে। এর মাধ্যমে TextBlock এর Text প্রপার্টি UserViewModel এর UserName প্রপার্টির সাথে বাইন্ড হবে।
  • যখন আপনি DataContext সেট করেন, তখন সেই DataContext এর সব প্রপার্টি UI উপাদানগুলির সাথে বাইন্ড হতে পারে।

DataContext এর সুবিধা:

  • UI উপাদানগুলোর জন্য একটি কেন্দ্রীয় ডেটা উৎস নির্ধারণ করা।
  • একাধিক UI উপাদান একই ডেটা মডেল ব্যবহার করতে পারে।
  • DataContext সেট করার পর, UI উপাদানগুলি স্বয়ংক্রিয়ভাবে সেই ডেটা মডেল থেকে ডেটা বাইন্ড করবে।

Data Template (ডাটা টেমপ্লেট)

Data Template হল একটি XAML উপাদান যা একটি ডেটা অবজেক্টের জন্য একটি ভিজ্যুয়াল রিপ্রেজেন্টেশন তৈরি করে। এটি UI উপাদানগুলোকে ডেটার কন্টেন্টের ভিত্তিতে কাস্টমাইজ করার জন্য ব্যবহৃত হয়। সাধারণত ডাটা টেমপ্লেট ব্যবহার করে একটি ডেটা মডেলের কন্টেন্টকে উপস্থাপন করা হয়।

উদাহরণ:

<Window x:Class="MyApp.MainWindow" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" Title="Main Window" Height="350" Width="525">
    <Window.Resources>
        <DataTemplate x:Key="PersonTemplate">
            <StackPanel>
                <TextBlock Text="{Binding FirstName}"/>
                <TextBlock Text="{Binding LastName}"/>
            </StackPanel>
        </DataTemplate>
    </Window.Resources>

    <ListBox ItemsSource="{Binding Persons}" ItemTemplate="{StaticResource PersonTemplate}"/>
</Window>

এখানে:

  • DataTemplatex:Key="PersonTemplate" দ্বারা একটি কাস্টম টেমপ্লেট তৈরি করা হয়েছে।
  • ListBox এর ItemTemplate প্রপার্টিতে সেই DataTemplate ব্যবহার করা হয়েছে, যা Persons (যেটি একটি কালেকশন) এর প্রতিটি আইটেমের জন্য FirstName এবং LastName প্রদর্শন করবে।

DataTemplate এর সুবিধা:

  • ডেটা মডেলকে ভিজ্যুয়ালভাবে কাস্টমাইজ করা।
  • ডেটার টাইপের উপর ভিত্তি করে UI কন্ট্রোলের কাস্টম রিপ্রেজেন্টেশন তৈরি করা।
  • ListBox, ComboBox, DataGrid ইত্যাদির মতো কন্ট্রোলগুলোর জন্য ডেটা ডিসপ্লে কাস্টমাইজ করা।

Binding, DataContext, এবং DataTemplate এর সম্পর্ক

  1. Binding হল ডেটা মডেল এবং UI উপাদানের মধ্যে ডেটা পাঠানোর পদ্ধতি।
  2. Data Context হল ডেটা বাইন্ডিংয়ের উৎস, যা UI উপাদান বা তার প্যারেন্ট উপাদানকে ডেটা মডেল বা ভিউ মডেল অ্যাসাইন করে।
  3. Data Template হল ডেটার ভিজ্যুয়াল রিপ্রেজেন্টেশন, যা একটি ডেটা মডেলের কন্টেন্টের জন্য কাস্টম UI উপাদান তৈরি করে।

এই তিনটি কনসেপ্ট একত্রে কাজ করে ডেটা মডেল এবং UI উপাদানের মধ্যে কার্যকর এবং নমনীয় সম্পর্ক স্থাপন করতে।


সারাংশ

  • Binding UI উপাদান এবং ডেটা মডেলের মধ্যে ডাইনামিক সংযোগ তৈরি করে।
  • Data Context ডেটা মডেল বা ভিউ মডেলকে UI উপাদানগুলির জন্য অ্যাসাইন করে।
  • Data Template ডেটা মডেলের কাস্টম ভিজ্যুয়াল রিপ্রেজেন্টেশন তৈরি করতে ব্যবহৃত হয়।
  • এই তিনটি কনসেপ্ট একসাথে ব্যবহার করলে UI এর সাথে ডেটার সম্পর্ক আরও শক্তিশালী এবং নমনীয় হয়, যা MVVM (Model-View-ViewModel) আর্কিটেকচারের জন্য আদর্শ।
Content added By
Promotion

Are you sure to start over?

Loading...